<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>文章列表</title>
    <link rel="stylesheet" href="./libs/bootstrap/css/bootstrap.min.css">
    <link rel="stylesheet" href="./css/reset.css">
    <link rel="stylesheet" href="./css/iconfont.css">
    <link rel="stylesheet" href="./css/main.css">
    <script src="./libs/jquery-1.12.4.min.js"></script>
    <!-- 引入模板引擎js文件 -->
    <script src="./libs/template-web.js"></script>
    <!-- 导入分页导航插件 -->
    <script src="./libs/jquery.twbsPagination.js"></script>
</head>

<body>
    <div class="container-fluid">
        <div class="common_title">
            文章列表
        </div>
        <div class="container-fluid common_con">
            <div class="row opt_btns">
                <div class="col-xs-6">
                    <form class="form-inline">
                        <select id="selCategory" name="" class="form-control input-sm">
                            <option value="">所有分类</option>
                            <option>未分类</option>
                            <option>奇趣事</option>
                            <option>会生活</option>
                            <option>爱旅行</option>
                        </select>
                        <select id="selStatus" name="" class="form-control input-sm">
                            <option value="">所有状态</option>
                            <option value="草稿">草稿</option>
                            <option value="已发布">已发布</option>
                        </select>
                        <button id="btnSearch" class="btn btn-default btn-sm">筛选</button>
                    </form>
                </div>
                <div class="col-xs-6">
                    <a href="article_release.html" class="btn btn-success btn-sm pull-right" id="release_btn">发表文章</a>
                </div>
            </div>
            <table class="table table-striped table-bordered table-hover mp20">
                <thead>
                    <tr>
                        <th>标题</th>
                        <th>作者</th>
                        <th>分类</th>
                        <th class="text-center">发表时间</th>
                        <th class="text-center">状态</th>
                        <th class="text-center" width="100">操作</th>
                    </tr>
                </thead>
                <tbody>
                    <tr>
                        <td>王积千造统最头</td>
                        <td>杰克</td>
                        <td>奇趣事</td>
                        <td class="text-center">2017-06-08 07:08:46</td>
                        <td class="text-center">已发布</td>
                        <td class="text-center">
                            <a href="article_edit.html" class="btn btn-default btn-xs">编辑</a>
                            <a href="javascript:void(0);" class="btn btn-danger btn-xs delete">删除</a>
                        </td>
                    </tr>
                </tbody>
            </table>
            <div class="row text-center">
                <!-- 分页导航容器 -->
                <ul id="pagination" class="pagination-sm"></ul>
            </div>
        </div>
    </div>
</body>

</html>
<script type="text/html" id="tpl-category">
    <option value="">所有分类</option>
    {{each data}}
    <option value="{{$value.id}}">{{$value.name}}</option>
    {{/each}}
</script>
<script type="text/html" id="tpl-list">
{{each data.data}}
<tr>
    <td>{{$value.title}}</td>
    <td>{{$value.author}}</td>
    <td>{{$value.category}}</td>
    <td class="text-center">{{$value.date}}</td>
    <td class="text-center">{{$value.state}}</td>
    <td class="text-center">
        <a href="article_edit.html?id={{$value.id}}" data-id="{{$value.id}}" class="btn btn-default btn-xs">编辑</a>
        <a href="javascript:void(0);" data-id="{{$value.id}}" class="btn btn-danger btn-xs delete">删除</a>
    </td>
</tr>
{{/each}}
</script>
<script src="./libs/https.js"></script>
<script>
    $(function () {
        // 获得当前所有文章类别，生成下拉框
        $.ajax({
            type: "get",
            url: BigNew.category_list,
            success: function (backData) {
                console.log(backData);
                if (backData.code == 200) {
                    // 结合模板引擎生成标签结构
                    let htmlStr = template("tpl-category", backData);
                    $("#selCategory").html(htmlStr);
                }
            }
        })
        let selPage=1;//声明一个变量来保存当前被选中的页码
        // 3.获得当前页面的文章列表数据
        function loadData(page) {
            selPage=page;
            $.ajax({
                type: 'get',
                url: BigNew.article_query,
                data: {
                    // 请求文章的类型
                    type: $("#selCategory").val(),
                    // 请求文章的状态:来自于文章状态下拉框
                    state: $("#selStatus").val(),
                    // 请求某一页的数据
                    page: page,
                    // 每页多少条数据
                    perpage: 5
                },
                success: function (backData) {
                    if (backData.code == 200) {
                       
                        if(backData.data.totalCount>0){
                            // 将返回的数据渲染到结构
                        let htmlStr = template("tpl-list", backData);
                        $("tbody").html(htmlStr);
                        // 测试引入分页插件
                        // 分页插件的属性设置只有第一次才能生效，第一次设置的总页数44
                        // 每次设置新的分页插件之前，必须先销毁之前
                        $('#pagination').twbsPagination('destroy');
                            $('#pagination').twbsPagination({
                                // 总页数
                            totalPages: backData.data.totalPage,
                            // 可见的页数
                            visiblePages: 7,
                            // 当前选中的页码
                            startPage:page,
                            // 关闭初始化点击事件
                            initiateStartPageClick:false,
                            // 修改按钮文字
                            first:"首页",
                            prev:'上一页',
                            next:'下一页',
                            last:'尾页',
                            // 分页导航页码点击事件
                            onPageClick: function (event, page) {
                                // page：当前点击的页面
                                loadData(page);
                            // 
                        },});
                        }else{
                            $("tbody").empty();
                            $("#pagination").text("当前类别没有任何文章.....")
                        }
                    }
                }
            })
        }
        // 首次加载第一页的数据
        loadData(1);
        // 给筛选按钮设置点击事件
        $("#btnSearch").on("click",function(e){
            e.preventDefault();
            // 重新获得文章数据，渲染结构
            loadData(1);
        })
        // 设置删除按钮点击事件
        $("tbody").on("click",".delete",function(){
            // 获得当前文章id值，通过模板引擎的自定义属性
            let dataID=$(this).attr("data-id");
            // 发起ajax请求，删除文章数据
            $.ajax({
                type:'post',
                url:BigNew.article_delete,
                data:{
                    id:dataID
                },
                success:function(backData){
                    if(backData.code==204){
                        //删除成功之后，重新加载数据
                        //注意：在哪一页删除，应该留在哪一页
                        if($('tbody tr').length>1){
                            loadData(selPage);
                        }else{
                            loadData(selPage-1);
                        }
                    }
                }
            })
        })
    })
</script>